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IN THE CLAIMS: 

i 1-22. (Cancelled) 

1 23. (Previously Presented) A storage controller, comprising: 

2 snapshot logic; 

3 copy logic; and 

4 an internal cache; 

5 the controller being operable to communicate with a replication manager to re- 

6 ceive a snapshot command issued by the replication manager, the snapshot command 

7 specifying a range of data bytes of a source volume; 

8 the controller being operable to communicate with the replication manager to re- 

9 ceive a copy specifying the source volume and a target volume; 

10 the controller being operable to receive a write command specifying the source 
n volume; 

12 the snapshot logic being operable, in response to the snapshot command, to take a 

13 snapshot of the range, the snapshot including a snapshot map and snapshot data, the snap- 

14 shot map being stored in a snapshot volume; and 

15 the copy logic being operable in response to receiving the copy command to gen- 

16 erate and send one or more storage device commands to one or more storage devices for 
n the source and target volumes to copy data from the source volume directly to the target 
is volume without having a file server in the data path, the copy logic using the snapshot 

19 map and the snapshot data to maintain coherency of the copied data. 

1 24. (Previously Presented) The storage device controller of claim 23, wherein the 

2 storage device controller is a RAID controller. 
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1 25. (Previously Presented) The storage device controller of claim 23, wherein: 

2 the range of the source specified by the snapshot command is a first range, and the 

3 write command specifies a second range of data bytes of the source volume; and 

4 the controller is operable, in response to receiving the write command while the 

5 source volume is being copied to the target volume, to hold the write command in the 

6 cache, check if the first range overlaps with the second range and, if so, copy the second 

7 range from the source volume to the snapshot volume, update the snapshot map, and then 

8 allow the write command to write the source volume. 

1 26. (Previously Presented) The storage device controller of claim 23, wherein the rep- 

2 lication manager is executed on a file server. 

1 27. (Previously Presented) The storage device controller of claim 26, wherein the file 

2 server is connected to a storage area network switch and the file server communicates 

3 with the storage device controller through the storage area network switch. 

1 28. (Previously Presented) The storage device controller claim 23, wherein the repli- 

2 cation manager is operable to control multiple storage device controllers. 

1 29. (Previously Presented) The storage device controller of claim 23, wherein: 

2 the one or more storage device commands include SCSI commands. 

1 30. (Previously Presented) The storage device controller of claim 23, wherein: 

2 the controller is operable to send the one or more storage device commands by 

3 using one of an in-band protocol or an out-of-band protocol. 
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1 31. (Previously Presented) A method comprising: 

2 receiving at a storage device controller a snapshot command issued by replication 

3 manager, the snapshot command specifying a rang of data bytes of a source volume; 

4 in response to receiving the snapshot command, the storage device controller tak- 

5 ing a snapshot of the range specified using device control commands to control one or 

6 more devices on which the source is stored, the snapshot including a snapshot map and 

7 snapshot data, and storing the snapshot map and the snapshot data in a cache internal to 

8 the storage device controller and snapshot volume, respectively; 

9 receiving at the storage device controller a copy command from the replication 

10 manager, the copy command specifying a copy operation from the source volume to a 
n target volume; and 

12 in response to receiving the copy command, the storage device controller generat- 

13 ing and sending storage device commands to one or more storage devices of the source 

14 and target volumes to copy data directly from the source volume to the target volume, the 

15 storage device controller also using the snapshot map and snapshot data to maintain co- 

16 herency of the copied data. 

1 32. (Previously Presented) The method of claim 31, wherein: 

2 the storage device is a RAID controller. 

1 33. (Previously Presented) The method of claim 31, wherein the range specified by 

2 the snapshot command is a first range, the method further comprising: 

3 receiving at the storage controller device a write command issued from file sys- 

4 tern, the write command specifying a second range of data bytes of the source volume, 

5 the write copy command being received while the source volume is being copied to the 

6 target volume; 
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7 in response to receiving the write command, the storage device controller holding 

8 the write command in the cache, checking if the first range overlaps with the second 

9 range and, if so, copying the second range from the source volume to the snapshot vol- 

10 ume, updating the snapshot map, and then allowing the write command to write to the 
n source volume. 

1 34. (Previously Presented) The method of claim 31 wherein the replication manager 

2 is executed on a file server. 

1 35. (Previously Presented) The method of claim 34, wherein the file server is con- 

2 nected to a storage area network switch and the file server communicates with the storage 

3 device controller through the storage area network switch. 

1 36. (Previously Presented) The method of claim 31, wherein the replication manager 

2 is operable to control multiple storage device controllers. 

1 37. (Previously Presented) The method of claim 31, wherein the storage device com- 

2 mands include a SCSI command. 

1 38. (Previously Presented) The method of claim 31, wherein the storage device com- 

2 mands are sent using one of an in-band protocol or an out-of-band protocol. 

1 39. (Previously Presented) A computer-implemented method comprising: 

2 using a replication manager to manage a source storage device controller and a 

3 destination storage device controller, the source storage device controller being operable 

4 to control access to a source data object and the destination device controller being oper- 
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5 able to control access to a destination data block, the storage device controllers being op- 

6 erable to issue storage device commands; 

7 internally generating within the source storage device controller in communica- 

8 tion with the replication manager, a snapshot version for each block of the source data 

9 object changed by one or more write operations to the block during the course of a copy 

10 operations; and 

n copying each block of the source data object to a corresponding block in the des- 

12 tination data object in the absence of the snapshot version of the block and otherwise 

13 copying the snapshot version of the source data object to block the corresponding block 

14 in the destination data object, wherein data is directly transferred between the source and 

15 destination storage device controllers without traversing a server operable to process file 

16 system requests, and wherein coherency of the data transferred between the source and 
n destination storage device controllers is maintained without requiring any file system to 
is maintain a snapshot map. 

1 40. (Previously Presented) A system comprising: 

2 a replication manager that is operable to issue a snapshot command; and 

3 a storage device controller that is operable (i) to communicate with the replication 

4 manager to receive the snapshot command and (ii) to receive a copy command, the snap- 

5 shot command specifying a range data bytes of a source volume, the copy command 

6 specifying the source volume and a target volume; wherein 

7 the controller is operable to receive a write command specifying the source vol- 

8 ume; 

9 the controller is operable, in response to receiving the snapshot command, to take 

10 a snapshot of the range, the snapshot including a snapshot map and a snapshot data, the 
n snapshot map being stored in a cache internal to the storage device controller and the 

12 snapshot data being stored to a snapshot volume; and 
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13 the controller is operable, in response to receiving the copy command, to generate 

14 and send one or more storage device commands to one or more storage devices for the 

15 sources and target volumes to copy data from the source volume directly to the target 

16 volume without having a file server in the data path, the controller using the snapshot 
n map and the snapshot data to maintain coherency of the copied data. 

1 41. (Previously Presented) The system of claim 40, wherein the replication manager 

2 is executed on a file server and is operable to control the source storage device controller 

3 and one or more other storage device controllers. 

1 42. (Previously Presented) The system of claim 40, further comprising a list of source 

2 data blocks to be copied that are reordered to increase copy speed. 

1 43. (Previously Presented) The system of claim 42, wherein the list of blocks to be 

2 copied is buffered while the storage device controller awaits further copy commands. 

1 44. (Previously Presented) The system of claim 40, wherein the replication manager 

2 is operable to inserted control data before and after a source data block being copied. 

1 45. (Previously Presented) The system of claim 40, wherein the replication manager 

2 is operable to specify a block size so that the storage device controller writes fixed- size 

3 blocks. 
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1 Please add new claims 46 et al. 

1 46. (New) A method, comprising: 

2 receiving a write request, wherein the write request has a range of data bytes to 

3 modify; 

4 determining the range of bytes is within a snapshot range, wherein a snapshot is a 

5 process of copying data to a new location before the data is modified by a write opera- 

6 tion; 

7 determining the range of bytes has not been snapshotted; 

8 in response to determining the range of bytes has not been snapshotted, copying 

9 the range of bytes from a source volume to a snapshot volume; 

10 updating a volume snapshot map, wherein the snapshot map determines which 
n blocks are located in the snapshot volume, in response to copying the range of bytes; 

12 modifying the range of bytes of data from the write request, in response to copy- 

13 ing the range of bytes; and 

14 copying the range of bytes from the source volume to a target volume using the 

15 volume snapshot map and data stored in the snapshot volume, and copying without hav- 

16 ing a file server in the path. 



